AMENDMENTS 



In the Claims 

1 . (Currently Amended) A method for operating a virtual machine within a data 
processing system, the method comprising the computer-implemented steps of: 

running a plurality of virtual machines on one or more devices within the data processing 
system, wherein each virtual machine in the plurality of virtual machines 
incorporates functionality for interoperating with other virtual machines in a the 
virtual machine cluster; 
associating the plurality of virtual machines in a virtual machine cluster, wherein each 
virtual machine in the virtual machine cluster acts as a node within the virtual 
machine cluster; and- 

sharing information about the plurality of virtual machines within the virtual machine 

cluster such that a virtual machine may be added to the virtual machine cluster or 
such that a virtual machine may be removed from the virtual machine cluster as 
the plurality of virtual machines continues to run , the sharing information further 
comprising sharing load values representing computer resource utilization among 
the virtual machines in the virtual machine cluster; 

performing a load-balancing operation across the virtual machine cluster; 

determining that a CPU load utilization on a first virtual machine exceeds a threshold 
value; and 

moving a thread from the first virtual machine to a second virtual machine during a load- 
balancing operation in response to the first virtual machine exceeding the 
threshold value . 
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2 - 4. (Canceled) 



5. (Currently Amended) The method of claim 3- 1 further comprising: 
determining that a memory load utilization on a first virtual machine exceeds a threshold 

value; and 

moving a set of one or more objects from the first virtual machine to a second virtual 
machine during a load-balancing operation. 

6. (Original) The method of claim 1 further comprising: 

moving a thread from a first virtual machine in the virtual machine cluster to a second 
virtual machine in the virtual machine cluster. 

7. (Original) The method of claim 1 further comprising: 

moving a set of one or more objects from a first virtual machine in the virtual machine 
cluster to a second virtual machine in the virtual machine cluster. 

8. (Original) The method of claim 1 further comprising: 

running a multi-threaded application within the virtual machine cluster; and 
dispatching threads of the multi-threaded application on different virtual machines such 
that execution of the multi-threaded application spans multiple virtual machines. 

9. (Currently Amended) A computer program product on a computer readable 
medium for use within executed by a data processing system for operating a virtual machine, the 
computer program product comprising: 

means for running one of a plurality of virtual machines on one or more devices within 
the data processing system, wherein each virtual machine in the plurality of 
virtual machines incorporates functionality for interoperating with other virtual 
machines in a the virtual machine cluster; 

means for associating a virtual machine with the plurality of virtual machines in a virtual 
machine cluster, wherein each virtual machine in the virtual machine cluster acts 
as a node within the virtual machine cluster; and 
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means for sharing information about the plurality of virtual machines within the virtual 
machine cluster such that a virtual machine may be added to the virtual machine 
cluster or such that a virtual machine may be removed from the virtual machine 
cluster as the plurality of virtual machines continues to run , the means for sharing 
comprising means for sharing load values representing computer resource 
utilization among the virtual machines in the virtual machine cluster; 

means for performing a load-balancing operation across the virtual machine cluster . 

means for determining that a CPU load utilization on a first virtual machine exceeds a 
threshold value; and 

means for moving a thread from the first virtual machine to a second virtual machine 
during a load-balancing operation in response to the first virtual machine 
exceeding the threshold value . 

10-12. (Canceled) 

13. (Currently Amended) The computer program product of claim 44 9 further 
comprising: 

means for determining that a memory load utilization on a first virtual machine exceeds a 
threshold value; and 

means for moving a set of one or more objects from the first virtual machine to a second 
virtual machine during a load-balancing operation. 

14. (Original) The computer program product of claim 9 further comprising: 
means for moving a thread from a first virtual machine in the virtual machine cluster to a 

second virtual machine in the virtual machine cluster. 

15. (Original) The computer program product of claim 9 further comprising: 
means for moving a set of one or more objects from a first virtual machine in the virtual 

machine cluster to a second virtual machine in the virtual machine cluster. 

16. (Original) The computer program product of claim 9 further comprising: 
means for running a multi-threaded application within the virtual machine cluster; and 
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means for dispatching threads of the multi-threaded application on different virtual 

machines such that execution of the multi-threaded application spans multiple 
virtual machines. 

17. (Currently Amended) An apparatus within a data processing system for operating 
a virtual machine, the apparatus being executed by a data processing system, t he apparatus 
comprising: 

means for running one of a plurality of virtual machines on one or more devices within 
the data processing system, wherein each virtual machine in the plurality of 
virtual machines incorporates functionality for interoperating with other virtual 
machines in a the virtual machine cluster; 

means for associating a virtual machine with the plurality of virtual machines in a virtual 
machine cluster, wherein each virtual machine in the virtual machine cluster acts 
as a node within the virtual machine cluster; and 

means for sharing information about the plurality of virtual machines within the virtual 
machine cluster such that a virtual machine may be added to the virtual machine 
cluster or such that a virtual machine may be removed from the virtual machine 
cluster as the plurality of virtual machines continues to run , the means for sharing 
information comprising means for sharing load values representing computer 
resource utilization among the virtual machines in the virtual machine cluster; 

means for performing a load-balancing operation across the virtual machine cluster 

means for determining that a CPU load utilization on a first virtual machine exceeds a 
threshold value; and 

means for moving a thread from the first virtual machine to a second virtual machine 
during a load-balancing operation in response to the first virtual machine 
exceeding the threshold value . 

18-20. (Canceled) 

2 1 . (Currently Amended) The apparatus of claim i9 17 further comprising: 
means for determining that a memory load utilization on a first virtual machine exceeds a 
threshold value; and 
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means for moving a set of one or more objects from the first virtual machine to a second 
virtual machine during a load-balancing operation. 

22. (Original) The apparatus of claim 17 further comprising: 

means for moving a thread from a first virtual machine in the virtual machine cluster to a 
second virtual machine in the virtual machine cluster. 

23. (Original) The apparatus of claim 17 further comprising: 

means for moving a set of one or more objects from a first virtual machine in the virtual 
machine cluster to a second virtual machine in the virtual machine cluster. 

24. (Original) The apparatus of claim 17 further comprising: 

means for running a multi-threaded application within the virtual machine cluster; and 
means for dispatching threads of the multi-threaded application on different virtual 

machines such that execution of the multi-threaded application spans multiple 

virtual machines. 
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